package com.docmgmt.mvp.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.docmgmt.mvp.entity.RoleEntity;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * 角色Mapper
 */
@Mapper
public interface RoleMapper extends BaseMapper<RoleEntity> {

    /**
     * 查询用户的所有角色
     * 注意：当前数据库设计使用sys_user.role_id直接关联（1:1），不使用sys_user_role表
     * sys_role表不使用软删除（无is_deleted字段）
     */
    @Select("SELECT r.* FROM sys_role r " +
            "INNER JOIN sys_user u ON r.id = u.role_id " +
            "WHERE u.id = #{userId}")
    List<RoleEntity> selectRolesByUserId(@Param("userId") Long userId);

    /**
     * 根据角色代码查询角色
     * sys_role表不使用软删除（无is_deleted字段）
     */
    @Select("SELECT * FROM sys_role WHERE role_code = #{roleCode}")
    RoleEntity selectByRoleCode(@Param("roleCode") String roleCode);
}
